package algorithm.binaryTreeAlgorithm;

import data.TreeNode;

import java.util.ArrayList;
import java.util.List;

/**
 * @ClassName: GetAllElements
 * @Description 1305. 两棵二叉搜索树中的所有元素
 * 给你 root1 和 root2 这两棵二叉搜索树。请你返回一个列表，其中包含 两棵树 中的所有整数并按 升序 排序。.
 * @Author skywingking
 * @Date 2022/5/1 20:54
 **/
public class GetAllElements {
    public List<Integer> getAllElements(TreeNode root1, TreeNode root2) {
        List<Integer> nums1 = new ArrayList<>();
        List<Integer> nums2 = new ArrayList<>();
        inorder(root1,nums1);
        inorder(root2,nums2);
        List<Integer> merged = new ArrayList<>();
        int p1 = 0,p2 = 0;
        while(true){
            if (p1 == nums1.size()) {
                merged.addAll(nums2.subList(p2, nums2.size()));
                break;
            }
            if (p2 == nums2.size()) {
                merged.addAll(nums1.subList(p1, nums1.size()));
                break;
            }
            if (nums1.get(p1) < nums2.get(p2)) {
                merged.add(nums1.get(p1++));
            } else {
                merged.add(nums2.get(p2++));
            }
        }
        return merged;
    }
    public void inorder(TreeNode node,List<Integer> res){
        if(node != null){
            inorder(node.left,res);
            res.add(node.val);
            inorder(node.right,res);
        }
    }

}